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Abstract. We describe a synchronous distributed algorithm which identifies 
the edge-biconnected components of a connected network. It requires a leader, 
and uses messages of size 0(log \ V\). The main idea is to preorder a BFS span- 
ning tree, and then to efficiently compute least common ancestors so as to mark 
cycle edges. This algorithm takes O(Diam) time and uses 0(|-E|) messages. 
Furthermore, we show that no correct singly-initiated edge-biconnectivity al- 
gorithm can beat either bound on any graph by more than a constant factor. 
We also describe a near-optimal local algorithm for edge-biconnectivity. 



1. Introduction 

The edge-biconnectivity problem is to partition the vertices of a graph into max- 
imal subsets called components such that the subgraph induced by each component 
remains connected after the deletion of any one edge. An edge whose deletion dis- 
connects a graph is called a bridge; identification of all bridges in a graph is roughly 
equivalent to computing its components. 

Here is a simple application of edge-biconnectivity. Given a (connected) com- 
munication network, let us compute its components. Two members of the network 
would be able to communicate despite the failure of any one communication link if 
and only if they are in the same component. Furthermore, for a given link, some 
members need that link to communicate if and only if that link is a bridge. This 
problem also has more sophisticated applications to module dependency |2U and 
efficient fault-tolerant broadcast |1 7). 

Connectivity is also important as a tool in graph theory. For example, vertex 
connectivity plays a major role in the theories of excluded minors and embeddings 
[201 123- There are sequential algorithms for /c-connectivity that are optimally ef- 
ficient — having O ( | V" | + \E\) time complexity — when k is small ^ n 
this paper we give an optimal edge-biconnectivity (k = 2) algorithm for distributed 
networks. Although this has been claimed before [3], our algorithm is optimal in a 
stronger sense: no correct distributed algorithm can outperform it on any graph. 

A recurring point will be that the "optimality" of an algorithm depends on 
what preliminary assumptions are made. This seems to come up in distributed 
algorithms more than in sequential algorithms due to the variety of models. Our 
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claims assume a synchronous network with a leader, and that the algorithm is event- 
driven, starting with a single initiator. These are the same assumptions made by 
the previous best edge-biconnectivity algorithm |28|. However, we also discuss how 
our algorithm performs under different assumptions. 



2. Preliminaries 

Throughout this paper, we write Q — (V, E) for a connected graph, with n = \V\ 
and to = \E\. We write Diam for the maximum distance between any two vertices 
of Q . We take Q to model a computer network, with nodes representing computers 
and edges representing two-way, reliable, communication links. 

Let us precisely state what edge-biconnectivity means. Define a relation ~ on 
V(G) by x ~ y if, despite the removal of any one edge from Q, there remains a 
path from x to y. It is easy to show that this is an equivalence relation, and we 
define the edge-biconnected components to be its equivalence classes. An edge is 
a bridge if its deletion causes Q to become disconnected. The connection between 
components, bridges, and cycles is shown by the following lemma, whose proof we 
postpone until Section 

Lemma 2.1. For a connected graph Q and (x,y) € E(Q), the following are equiv- 
alent: 

(1) x and y are in the same biconnected component, 

(2) (x, y) is not a bridge, 

(3) x and y lie in a simple cycle. 

We will give a distributed algorithm for computing the edge-biconnected compo- 
nents of any graph. Where there is no confusion, we write "biconnectivity" instead 
of "edge-biconnectivity." At the end of the algorithm, each node will store a label 
corresponding to its biconnected component. Thus, by Lemma \'2. II a given edge is 
a bridge if and only if its two endpoints store different labels. 

We will assume that the network is synchronous. This common assumption is 
validated by synchronizers 0, by which our synchronous algorithm can be efficiently 
made into an asynchronous algorithm. We also assume that the network initially 
contains a distinguished node called the leader. If we do not make this assumption, 
then we instead use an existing leader election algorithm [J at an overhead of 0{n) 
time and 0(m + rtlogn) messages. 

This biconnectivity algorithm communicates, for the most part, along a spanning 
tree of the network. The key point is that we can use a tree to efficiently identify 
which edges lie in cycles, and then apply Lemma |2.1I We distributively compute 
a pre-ordering of V, and using "least common ancestors" we efficiently identify all 
cycle edges. Then it is straightforward to identify the bridges. Finally, we label the 
components using the following lemma. 

Lemma 2.2. If we delete all bridges of Q from a spanning tree ofQ, then the forest 
of resulting trees is a set of spanning trees for the biconnected components of Q. 
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The important point is that, in comparison to DFS-based distributed biconnec- 
tivity algorithms such as pQ ^1] [B], our algorithm works on any tree. Whereas DFS 
seems to require Cl(n) time, using BFS in our algorithm keeps the time complexity 
low. The idea of using an arbitrary tree for bridge-finding was first published in a 
1974 paper by Tarjanj^B], and was generalized somewhat in |29| . 

All messages in the algorithm are O(logn) bits long, and thus it meets the 
CONGEST model of j2H]. Our algorithm takes 0(Diam) time and sends 0(m) 
messages. The previous best time complexity for a biconnectivity algorithm is 
(3(Diam + n 614 ) from [2SI ■ Given that this is the same as our bound when 
Diam > n 0,614 , one may wonder whether we have really improved the situation. 
Happily, we can show that this new algorithm is universally optimal: any event- 
driven biconnectivity algorithm with a single initiator must take i7(Diam(£/)) time 
and use Q(m(Q)) messages for every possible graph Q, or else the algorithm is 
incorrect on some graphs. 

For reference, we note other previous work on biconnectivity. The distributed 
algorithm of ^B] is the most similar to ours, as it takes an arbitrary tree, but it 
uses 0(mn) messages. The parallel algorithms of [231231 also use an arbitrary tree. 
The distributed algorithm of uses an "ear decomposition" of the network and 
takes 0(n) time. Several others [HHHIS] use messages of size f2( n ) bits, including 
an incremental algorithm [21] and a self-stabilizing algorithm 18 . Another self- 
stabilizing algorithm [H] takes 0(n 2 ) time. 

3. Overview of the Algorithm 

We use a rooted tree T in our algorithm. An edge of Q which does not lie in 
T is called a cross edge. Let h(T) denote the height of T, and desc(v) denote the 
descendants of v in T, including v itself. Let C denote the union of all simple cycles, 

C := {e G E | e lies within some simple cycle of Q}. 

The algorithm operates in five phases, as follows: 

(1) Construct a rooted breadth-first search (BFS) tree T. 

(2) At each node v, compute #c?esc(w), the number of descendants of v in T. 

(3) Compute a preorder labeling of V{Q) with respect to T. 

(4) By sending messages from cross edges up to the root, mark each edge in C. 

(5) By downcasting, label the nodes according to their biconnected compo- 
nents. 

4. Tree Construction and Preorder Labeling 

First, we need a rooted spanning tree T. The algorithm runs fastest when T 
is a BFS tree, but for the purposes of correctness any tree will do. We assumed 
that there is a leader in the network, and given this leader, it is straightforward to 
construct a rooted spanning tree. This is a well-studied problem, see for example 
|23j . In what follows, we use the term downcasting to mean that the root sends a 
message to all of its children, each of which sends a message to each of its children, 
and so forth. Convergecasting j2H] means an inverse process, where messages are 



4 



D. PRITCHARD 



propagated from leaves to their parents, and so on up the tree to the root; however, 
each node waits to hear from all of its children before reporting to its parent, so 
only n — 1 messages are sent in total. 

The computation of #desc(v) at each node in Phase 2 can be accomplished 
in 2h(T) time steps. First, the root node sends "Compute #desc of yourself to 
each of its children, and this message is downcasted through all of T. Each leaf v 
determines immediately that #desc(v) = 1. Once any non-root node computes its 
#desc value, it sends a message to its parent indicating that value. Each non-leaf 
node v aggregates its childrens' values in order to compute #<iesc(f ); namely, if v 
has children ci, . . . , then v may compute 

k 

#desc(w) := 1 + ffdesc(ci). 

i=l 

In Phase 3, a preorder labeling of T is computed by using another downcast. 
The root node starts by setting its own PreLabel field to 1. Whenever a node v sets 
its PreLabel field to £, it orders its children in T arbitrarily as ci, eg, . . .. Then v 
sends the message "Set your PreLabel field to to each a, where li is computed 
by v as 

U = £ + l + ^2#desc(cj) 

j<i 

After h{T) time steps, we will have computed a preordering of T. 

5. Least Common Ancestors 

In order to simplify the presentation, we hereafter refer to nodes simply by their 
preorder labels. The preordering allows us to reduce congestion in Phase 4 of the 
algorithm, using the following properties. 

Lemma 5.1. The descendants of a node v in the tree Tare precisely 
desc(v) = {u|ii<ji<h + #desc(v)}. 

Let LCA(mi, 1*2, . . .) denote the lowest (by position, not value) common ancestor 
of nodes iti, u%, . . . in the tree T. In other words, LCA(ui, U2, . . .) is an ancestor of 
each Ui, but no strict descendant of LCA(ui, U2, . . .) is an ancestor of all UiS. 

Theorem 5.2. If v\ < vi < V3, then LCA(-ui,t>3) is an ancestor of vi- 

Proof. Let a = LCA(vi, V3). By Lemma f5. II a < v\ < W3 < a + ffdesc(a). Thus 
a < V2 < a + 4f z dGsc{a), and by Lemma fo. II V2 must also be a descendant of a. □ 

Corollary 5.3. LCA(ui, U2, . . . Uk) — LCA(mini(iti), maxi(ztj)). 
Corollary 5.4. // u,; < Vi for all i, then 

LCA(LCA(ui, vi), LCA(w 2 , v 2 ), ■ ■ ■ LCA(u fc , v k )) = LCA(min(Mi), max^)). 
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6. Marking Cycle Edges 

The goal of Phase 4 is to determine which edges lie in C. When v' is an ancestor 
of v in T, let Chain(v', v) denote the set of edges on the path from v' to v in T. 
The cross edges with respect to T permit a simple formula for C: 

Lemma 6.1. 

(1) C= (J {(u,u)}UChain(LCA(u,u),u)UChain(LCA(u,w),-y). 

(u,v)eg-T 

Proof. Note that each set {{u, v)} U Chain(LCA(u, v), u) U Chain(LCA(u, v), v) is 
a simple cycle. It remains to show that this union formula contains all edges 
appearing in simple cycles. Suppose otherwise, that the above formula missed 
some edge (u, v) belonging to a simple cycle K of Q. Since Equation includes 
all edges of Q — T, we can assume that (u, v) 6 T, without loss of generality u the 
parent of v. 

Let the cycle K contain, in order, the nodes (ko — v, fei, fca, ■ ■ ■ , k m —i = u, k m = 
v). If ki is the first element of this list not in desc(v), then (fej-i, fcj) is a cross edge. 
But then we have 

(it, v) G Chain(LCA(fc,;_i, fci), fci_i), 
so in fact (u,v) is counted by 0). □ 

Thus, to mark the edges of C, it suffices to just mark chains going up from each 
cross edge to its endpoints' LCA. 

We could distributively mark the edges in Chain(LCA(it, v), v) as follows: 

• For each cross edge (u,v), 

Send a message from v to u which states "If you are an ancestor of 
both u and v, then ignore this message. Otherwise, pass this message up 
to your parent, and mark the edge joining you to your parent as being in 
C" 

Send the same message from u to v. 

Checking the ancestry condition is accomplished using Lemma HTT1 We will abbre- 
viate the message "If you are an ancestor of both u and v, ..." as "Mark up to 
LCA(m, v)" . Without loss of generality, we will send our messages so that u < v. 

Sending these messages naively leads to congestion. When a node receives many 
at once that must all be forwarded, not all can be immediately sent to its parent if 
the O(logn) bound on message sizes is to be respected. The following Forwarding 
Rule fixes this congestion: 

• If a node w receives several messages "Mark up to LCA(ui, •»,)" for i — 
1 . . . k, it should compute u m i n = minj itj and w max = max^ wj. If w is an 
ancestor of both it m i n and i> ma x, then no message is sent up. Otherwise, 
w should send "Mark up to LCA(u m i n , w max )" to its parent, and mark the 
edge connecting w to its parent as being in C. 
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Theorem 6.2. The Forwarding Rule correctly marks Chain(LCA(u, v), v) for each 
cross edge (u, v). 

Proof. Suppose that w, as described, is asked to propagate messages so that all 
edges in 

I^J Chain(LCA(ui, Vi), w) 

i 

become marked. They must all lie on the unique path between w and the root 
of T, so we only need to mark the longest chain. The highest LCA is equal to 
LCA(LCA(ui, v\), LCA(u 2 , V2), ■ ■ ■) and by Corollary 15.41 this is LCA(u min , u max ), 
so the propagated message (if any) is correct. □ 

7. BlCONNECTED DECOMPOSITION 

Lemma 7.1. For a connected graph Q and 1,!/ e V(Q), x and y are in the same 
biconnected component if and only if x and y both lie in some cycle of Q that has 
no repeated edges. 

Proof. Note that x 7^ y if and only some edge's deletion separates x from y; by 
the maxflow-mincut theorem such an edge exists if and only if there are not two 
edge-disjoint paths between x and y. Those paths' union is precisely a cycle with 
no repeated edges, and likewise such a cycle can be broken into two edge-disjoint 
x-y paths. □ 

We now prove the Lemma introduced in Section [21 

Lemma 12.11 For a connected graph Q and (x,y) 6 E(Q), the following are equiv- 
alent: 

(1) x and y are in the same biconnected component, 

(2) (x,y) is not a bridge, 

(3) x and y lie in a simple cycle. 

Proof. Let e denote the edge {x,y). 

(3) =^ (2) : Let C be a cycle containing x and y. For any u-v path containing e, 
we can use C — e to connect u and v in Q — e, and thus e is not a bridge. 

-i(2) : If x 9^ y, then the deletion of some edge from Q causes x and y to 
become separated. But x remains connected to y by e unless e is the deleted edge. 
Thus the deletion of e from Q separates x from y, so e is a bridge. 

(1) =>■ (3) : Apply Lemma f?~Tl obtaining cycle C with no repeated edges. If 
e ^ C, then we take any simple x-y path in C and adjoin e to create a simple cycle 
containing x and y. If e G C, then partition C into simple cycles, and take the one 
containing e. □ 



Note that only tree edges can be bridges, for each cross-edge induces a cycle with 
T. Thus, if each node stores a boolean variable indicating whether the edge to its 
parent is a bridge, then this suffices to identify all bridges. 
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Figure 1. Distributed algorithm for edge-biconnectivity, given a 
rooted spanning tree. 
[Algorithm specification omitted, as arxiv does not support the algpseudocode 

class] . 

To group the nodes according to their biconnected component (Phase 5), we 
need to broadcast an identifier along each component. The following claim means 
that a simple downcast along the edges of T will suffice. 

Lemma 12.21 If we delete all bridges of Q from T, then the forest of resulting trees 
is a set of spanning trees for the biconnected components of Q. 

Proof. Suppose otherwise, that there are two nodes u ~ v such that the unique 
path P between u and v in T contains a bridge e. Since u ~ v , there is a simple 
u-v path P' in Q — e. But then the symmetric difference PAP' has even degree at 
every node and contains e, and so PAP' contains some simple cycle containing e. 
By Lemma 12. II we have a contradiction. □ 

8. Correctness and Complexity of the Algorithm 

The main parts of the algorithm, Phases 4 and 5, are shown in Algorithm^ Its 
correctness follows from Lemma [fi. II Theorem 16 . 21 and Lemma \'2. 21 Note that we 
specify "null" messages which we have not yet been justified; this is in order for the 
"Mark up to" messages to be properly synchronized in a convergecast. This way, 
a node simply waits to hear from all of its non-parent neighbours before reporting 
to its parent. 

Phases 2-4 have total message complexity 0(n) and time complexity 0(h(T)), 
even in an asynchronous setting. Thus, those phases would be optimized when T 
is as short as possible. Note that a BFS tree has height at most Diam(C/), and that 
no spanning tree has height less than Diam(C?)/2. Thus, it is essentially optimal 
to construct a BFS tree in Phase 1. Assuming synchrony, and that we are given 
a leader at the beginning of the algorithm, it is well-known that a BFS tree can 
be constructed greedily in 8(Diam) time and using 0(m) messages. Thus, the 
biconnectivity algorithm's total complexity is O(Diam) time and O(m) messages. 

9. Optimality 

We claim that the performance of this algorithm cannot be improved beyond 
constant factors. To be precise, we argue that any deterministic, singly-initiated, 
event-driven protocol for bridge-finding must always send at least m messages and 
take at least Diam/2 time, or else the protocol will not work on all graphs. By singly- 
initiated, we mean that there is a single node in the graph which begins computing 
spontaneously, and by event-driven we mean that every other node must receive 
a message before it can perform any action. These lower bounds are similar in 
nature, and both depend on the fact that the whole network must be explored. 
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Figure 2. Modification of Q into Q' , upon which a biconnectivity 
algorithm fails. 

First we describe the lower bound for messages. Suppose that, when the protocol 
is executed on some graph Q, there is an edge (it, v) along which no messages are 
sent. Let Q' be a graph obtained from Q by adding a new node w and dividing (it, v) 
into two edges (it, w) and (w,v). We also attach some cycles and bridges to w, as 
shown in Figure|21 When we run the protocol on Q' , assuming that the algorithm is 
deterministic, no messages are sent along (u, w) or (w, v) and so no messages reach 
the new nodes and edges. Consequently, the algorithm cannot correctly determine 
whether the new edges are bridges or not. 

The lower bound on the time complexity is similar. If an algorithm uses takes 
less than Diam((J)/2 steps on some graph Q, then there are parts of the graph which 
no messages reach. Consequently, we can modify Q so that the algorithm operates 
incorrectly. 

Note that these lower bounds apply to all graphs. In comparison, a 0(n)-time 
algorithm of [S] was called "optimal" because some graphs require 0(n) time to find 
their bridges. The 0(n) algorithm is existentially optimal, since there exist some 
instances on which the protocol is optimal, and our O(Diam) algorithm is universally 
optimal, since it has optimal running time on all instances. The different types of 
optimality were first observed by |22 and pi m the context of leader election, 
and further discussion appears in J3| and |1U|. Universal optimality allows us to 
precisely state that the inherent complexity of the (singly-initiated, event-driven) 
biconnectivity problem is 9(Diam) time and 0(m) messages. Finally, although we 
state these bounds for deterministic algorithms, similar bounds can be proved for 
randomized ones, using essentially the same argument. 

10. A Near-Optimal Local Algorithm 

For now, let us forget the problem of labeling nodes according to their bicon- 
nected component, and only worry about identifying all of the bridges in a graph. 
We consider initiating all nodes at the same time, and want to know how long it will 
be before all edges are correctly identified as bridges or non-bridges. By removing 
the assumption of a single initiator, we can beat the lower time bound of Diam. 

Suppose we remove the restriction on the message size. Then, each node can 
broadcast everything it knows about its local topology after each step, and so after t 
steps each node will know its own ^neighbourhood. Here is an algorithm for bridge- 
finding. Initially, each edge is assumed to be a bridge; whenever a node learns of 
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a cycle in its neighbourhood, it informs all of the edges in that cycle that they are 
not bridges. In this way we distributively determine C, the union of all cycles in 
Q. For a general graph, we cannot be sure that we're done until Diam steps have 
elapsed. However, for certain graphs, we can safely terminate in o(Diam) rounds. 
An algorithm whose time complexity is o(Diam) is often called local. 

Now, let us determine the time before this algorithm has correctly identified 
the non-bridges. A non-bridge e will be identified as soon as a cycle containing 
e is known by a node; we call such a cycle a witness for e. We need each edge 
to be identified by a witness in order for the algorithm to be correct. Define the 
cycle-witness radius of denoted T(Q), by 

¥(Q) := max min min max distc (u, v). 

e£C K a cycle veV(Q) u£K 
KBe 

Then the cycle-witness radius is the minimum time needed to identify all of the 
non-bridges (and, it will take another T(Q) rounds to notify those edges). Further, 
it can be shown that T(Q) is a lower bound on the number of rounds before all 
non-bridges can be correctly identified. 

A (log n, T)-neighbourhood cover of Q is a collection of connected vertex sets 
called clusters such that 

(1) For each vertex v, the T-neighborhood of v is entirely contained in some 
cluster. 

(2) The subgraph of Q induced by each cluster has diameter O(Tlogn). 

(3) Each node belongs to O(logn) clusters. 

See [221 Ch. 21] for a good exposition on this subject. The full version of JU| gives 
a randomized local algorithm for computing sparse neighborhood covers which, 
with high probability, runs in 0(Tlog 3 n) time and uses 0(m log 2 n) messages on 
a synchronous network. 

We can use neighbourhood covers to search brute-force for all small cycles, with- 
out using large messages as described above. Suppose we have a (logn, T) neigh- 
bourhood cover as described above. Each edge has a witness that is entirely con- 
tained within one cluster. If we run Algorithm ^ separately on each cluster, each 
non-bridge will be witnessed in some cluster. Since each node may be in O(logn) 
clusters, there will be congestion when we process all clusters in parallel; how- 
ever, this will only increase the time of the biconnectivity algorithm by a factor of 
0(log n), since each node can rotate between participating in its containing clusters. 
The resulting local algorithm takes 0(Tlog 3 n) time and 0(m log 2 n) messages to 
construct the clusters, then a further O(Tlogn) time and 0(m log n) messages to 
determine the non-bridges. 

Finally, it is unlikely that T can be computed efficiently and/or locally. However, 
an algorithm can successively "guess" T = 1, 2, 4, 8, . . . , and run the local algorithm 
for each value in turn. Once the guess is larger than the actual value of T, all 
edges will be correctly classified; this algorithm becomes correct within 0(T log 3 n) 
rounds. We note that this is essentially a will-maintaining algorithm as defined by 
Elkin in HO]. 
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11. Other Extensions 

With a small modification, the algorithm of this chapter can also be used to com- 
pute the strongly-connected components of a graph. We require that all directed 
edges function as 2-way communication channels. We compute a directed DFS tree 
T of the network. It is easy to show that an analog of Equation JJJ holds in this 
case, with the cross edges replaced by the back edges {(u,v) | u 6 desc(v)}. The 
resulting algorithm takes 0(h(T)) time and 0(m) messages, identifies the edges 
that belong to cycles, and labels all nodes according to their strongly-connected 
component. Using Awerbuch's DFS algorithm from |3] gives a total of 0(n) time 
and 0(m) communication complexity and note that it works on asynchronous net- 
works. 

If a short DFS tree could be identified in sub-linear time, then we might be able 
to get a sub-linear algorithm for identifying strongly connected components. 

Question 11.1. Does there exist a (O(Diam) + o(n))-time distributed DFS tree 
construction algorithm, using messages of size O(logn)? 

Also, there is a divide-and-conquer algorithm |llj for strongly connected com- 
ponents which might lend itself to distributed implementation in sub-linear time. 

In order to ensure reliability in networks, one may want to ensure the 2-vertex 
connectivity of a network, for example |17j . It does not seem that our algorithm 
can be easily modified to determine vertex biconnectivity. In contrast, the 0(n) 
time DFS-based biconnectivity algorithms of and ^3] can determine vertex 
biconnectivity. 

We might also try to determine the triconnected |15j components of a graph. 
There are efficient parallel algorithms for this problem |T2]. The following lemma 
might be useful in designing a fast distributed triconnectivity algorithm. 

Claim 11.2. Let Q be a graph with no bridges. Define the relation on the edges 
of ' Q by x r*J D y if the graph Q — x — y is not connected. Then is an equivalence 
relation. 

References 

[1] M. Ahuja and Y. Zhu. An efficient distributed algorithm for finding articulation points, 
bridges, and biconnected components in asynchronous networks. In Proc. 9th Conf. Founda- 
tions of Software Technology and Theoretical Computer Science, pages 99-108, 1989. 

[2] B. Awerbuch. Complexity of network synchronization. J. ACM, 32(4):804-823, 1985. 

[3] B. Awerbuch. A new distributed depth-first-search algorithm. Inform. Process. Lett., 20:147- 
150, 1985. 

[4] B. Awerbuch. Optimal distributed algorithms for minimum weight spanning tree, counting, 
leader election, and related problems. In Proc. 19th Symp. Theory of Computing, pages 230- 
240, 1987. 

[5] B. Awerbuch. Distributed shortest paths algorithms. In Proc. 21st Symp. Theory of Com- 
puting, pages 490-500, 1989. 

[6] J.-C. Bermond and J.-C. Konig. General and efficient decentralized consensus protocols II. In 
M. Cosnard et al., editor, Parallel and Distributed Algorithms, pages 199—210. North-Holland, 
1988. 

[7] E. J.-H. Chang. Echo algorithms: Depth parallel operations on general graphs. IEEE Trans. 
Softw. Eng., SE-8:391-401, 1982. 



OPTIMAL DISTRIBUTED EDGE-BICONNECTIVITY 



11 



P. Chaudhuri. An optimal distributed algorithm for computing bridge-connected components. 
The Computer Journal, 40(4):200-207, 1997. 

P. Chaudhuri. An 0(n 2 ) self-stabilizing algorithm for computing bridge-connected compo- 
nents. Computing, 62:55—67, 1999. 

M. Elkin. A faster distributed protocol for constructing a minimum spanning tree. 
In Proc. 15th Symp. Discrete Algorithms, pages 359-368, 2004. Full version at 
http : //www. cs .yale . edu/~elkin/mst . jour .ps 

L. Fleischer, B. Hendrickson, and A. Pinar. On identifying strongly connected components 
in parallel. In Proc. 15th IPDPS Workshops on Parallel and Distributed Processing, pages 
505-511, 2000. 

D. S. Fussell, V. Ramachandran, and R. Thurimella. Finding triconnected components by 
local replacement. SI AM J. Comput., 22:587-616, 1993. 

J. A. Garay, S. Kutten, and D. Peleg. A sublinear time distributed algorithm for minimum- 
weight spanning trees. SI AM J. Comput., 27(1):302-316, 1998. 

W. Hohberg. How to find biconnected components in distributed networks. J. Parallel Distrib. 
Comput., 9(4):374-386, 1990. 

J. E. Hopcroft and R. E. Tarjan. Dividing a graph into triconnected components. SIAM J. 
Comput., 2(3):135-158, 1973. 

S. T. Huang. A new distributed algorithm for the biconnectivity problem. In Proc. 1989 
International Conf. Parallel Processing, pages 106-113, 1989. 

A. Itai and M. Rodeh. The multi-tree approach to reliability in distributed networks. Inf. 
Comput., 79(l):43-59, 1988. 

M. H. Karaata. A stabilizing algorithm for finding biconnected components. J. Parallel Dis- 
trib. Comput., 62(5):982-999, 2002. 

A. Kazmierczak and S. Radhakrishnan. An optimal distributed ear decomposition algorithm 
with applications to biconnectivity and outerplanarity testing. IEEE Trans. Parallel Distrib. 
Syst., 11(2):110-118, 2000. 

L. Lovasz. Graph minor theory. Bull. Amer. Math. Soc. (N.S.), 43(l):75-86, 2006. 

C. H. Papadimitriou and D. Ratajczak. On a conjecture related to geometric routing. Theoret. 
Comput. Set., 344(1):3-14, 2005. 

D. Peleg. Time-optimal leader election in general networks. J. Parallel Distrib. Comput., 
8(l):96-99, 1990. 

D. Peleg. Distributed Computing: A Locality-Sensitive Approach. SIAM, 2000. 

B. Swaminathan and K. J. Goldman. An incremental distributed algorithm for computing 
biconnected components in dynamic graphs. Algorithmica, 22:305-329, 1998. 

R. Tarjan. Depth first search and linear graph algorithms. SIAM J. Comput., 1(2):146-160, 
1972. 

R. E. Tarjan. A note on finding the bridges of a graph. Inform. Process. Lett., 2:160—161, 
1974. 

R. E. Tarjan and U. Vishkin. An efficient parallel biconnectivity algorithm. SIAM J. Comput., 
14(4):862-874, 1985. 

R. Thurimella. Sub-linear distributed algorithms for sparse certificates and biconnected com- 
ponents. In Proc. Hth Symp. Principles of Distributed Computing, pages 28-37, 1995. 
Y. H. Tsin and F. Y. Chin. A general program scheme for finding bridges. Inform. Process. 
Lett., 17(5):269-272, 1983. 

J. Woo and S. Sahni. Computing biconnected components on a hypercube. J. Supercomputing, 
5:73-87, 1991. 



Department of Combinatorics and Optimization, Waterloo, Canada. 



